草庐IT

php - 压缩一个php数组

全部标签

ruby-on-rails - Ruby/RoR - 计算数组中元素的出现次数

我有一个哈希{1=>true,7=>false,6=>true,4=>false}或者像这样的数组[1,true],[7,false],[6,true],[4,false]]或[真、假、真、假]。如何找到数组中true的个数? 最佳答案 为了对元素进行计数,您显然必须遍历集合。由于遍历Hash会产生两个元素的Array,因此前两个实际上完全相同:{1=>true,7=>false,6=>true,4=>false}.count(&:last)[[1,true],[7,false],[6,true],[4,false]].count(

ruby-on-rails - 对哈希数组中的值求和的更好方法

关闭。这个问题是off-topic.它目前不接受答案。想改进这个问题吗?Updatethequestion所以它是on-topic用于堆栈溢出。关闭9年前。Improvethisquestion我需要对数组哈希中的值求和,我找到了一种方法来做到这一点here但在Ruby中似乎应该有更优雅的方式。这是有效的;sales=[{"sale_price"=>210000,"deed_type"=>"WarrantyDeed"},{"sale_price"=>268300,"deed_type"=>"WarrantyDeedJoint"}]total_sales=sales.inject(0){

ruby - 测试变量是否与多个字符串中的任何一个匹配,而没有长的 if-elsif 链或 case-when

我想在ruby​​中有一种很好的单行方式来表达ifmystr=="abc"or"def"or"ghi"or"xyz"但在我通常查阅的在线引用资料中找不到如何做到这一点...谢谢! 最佳答案 也许你不知道你可以在一个案例上放置多个条件:casemystrwhen"abc","def","ghi","xyz"..end但是对于这个特定的基于字符串的测试,我会使用正则表达式:ifmystr=~/\A(?:abc|def|ghi|xyz)\z/如果您不想构造正则表达式,也不想使用case语句,您可以创建一个对象数组并使用Array#incl

ruby - 在 Rails 中使用 uuidtools 生成一个短的 UUID 字符串

我必须生成一个唯一的随机字符串,并将其存储在数据库中。为此,我使用了“uuidtools”gem。然后在我的Controller中添加了以下行:require"uuidtools"然后在我的Controller创建方法中,我声明了一个“temp”变量并生成一个唯一且随机的“uuid”字符串,如下所示:temp=UUIDTools::UUID.random_create它正在创建这样一个字符串:f58b1019-77b0-4d44-a389-b402bb3e6d50现在我的问题是我必须让它简短,最好在8-10个字符以内。现在我该怎么做??是否可以传递任何参数以使其成为所需长度的字符串?提

ruby-on-rails - 计算数组元素之间的差异

给定一个由n个整数组成的有序数组,如下所示:ary=[3,5,6,9,14]我需要计算数组中每个元素与下一个元素之间的差异。使用上面的例子,我最终会得到:[2,1,3,5]起始数组中可能有0个、1个或多个元素,我要处理的数字会大得多(我将使用纪元时间戳)。我尝试了以下方法:times=@messages.map{|m|m.created_at.to_i}left=times[1..times.length-1]right=times[0..times.length-2]differences=left.zip(right).map{|x|x[0]-x[1]}但我上面的解决方案既不是最优

Ruby - 查找两个数组不相同的元素

我一直在思考以下问题-有两个数组,我需要找到它们不常见的元素,例如:a=[1,2,3,4]b=[1,2,4]预期的答案是[3]。到目前为止,我一直这样做:a.select{|elem|!b.include?(elem)}但它给了我O(N**2)时间复杂度。我相信它可以更快地完成;)此外,我一直在考虑以这种方式获取它(使用一些与&相反的方法,它给出了2个数组的公共(public)元素):a!&b#=>doesn'tworkofcourse另一种方法可能是将两个数组相加并使用类似于uniq的方法找到唯一元素,这样:[1,1,2,2,3,4,4].some_method#=>wouldret

ruby - 创建一个固定大小的数组,并用另一个数组填充默认内容?

我想创建一个固定大小的数组,其中默认数量的元素已经从另一个数组中填充,所以假设我有这个方法:deffixed_array(size,other)array=Array.new(size)other.each_with_index{|x,i|array[i]=x}arrayend那么我可以使用如下方法:fixed_array(5,[1,2,3])我会得到[1,2,3,nil,nil]在ruby​​中有更简单的方法吗?就像用nil对象扩展我已有的数组的当前大小一样? 最佳答案 deffixed_array(size,other)Arra

ruby - 如何检查一个范围是否包含另一个范围的子集?

如果我有两个重叠的范围:x=1..10y=5..15当我说:putsx.include?y输出是:false因为这两个范围只是部分重叠。但是如果我希望它在两个范围之间有部分重叠时为“真”,我该如何写呢?换句话说,我需要一种方法来知道一个范围何时包含另一个范围的子集。我认为有一种优雅的方式可以用Ruby编写它,但我能想到的唯一解决方案是冗长的。 最佳答案 有效的方法是比较极限(x.first 关于ruby-如何检查一个范围是否包含另一个范围的子集?,我们在StackOverflow上找到一

Ruby 数组 reverse_each_with_index

我想在数组上使用类似reverse_each_with_index的东西。例子:array.reverse_each_with_indexdo|node,index|putsnodeputsindexend我看到Ruby有each_with_index但它似乎没有相反的。还有其他方法吗? 最佳答案 如果你想要数组中元素的真实索引,你可以这样做['Seriously','Chunky','Bacon'].to_enum.with_index.reverse_eachdo|word,index|puts"index#{index}:#{

ruby - 断言 Cucumber 中抛出了一个特定的异常

场景我正在编写一个库(没有RubyonRails),我想为其提供非常详细的Cucumber功能。这尤其包括描述在各种情况下应该抛出的错误/异常。示例编写Cucumber步骤最直观的方式可能是这样的WhenIdosomethingunwantedThenan"ArgumentError"shouldbethrown问题我必须解决两个问题:抛出异常时,第一步不应失败。第一步抛出的异常应该可供第二步访问,以便执行一些断言魔法。不优雅和繁琐的解决方案我能想到的最佳方法是在第一步中缓存异常并将其放入第二步可以访问的实例变量中,如下所示:When/^Idosomethingunwanted$/do